
.eap-header {
  width: 100%;
  height: 52px;
  background-color: #fff;
  position: sticky;
  top: 0;
  left: 0;
  right: 0;
  z-index: 99999;
}

@media (min-width: 769px) {
  .eap-header {
    height: 80px;
    position: relative;
  }
}

.separator {
  display: none;
  position: absolute;
  top: 52px;
  left: 0;
  right: 0;
  background-color: #e5e5e5;
  height: 1px;
}

@media (min-width: 769px) {
  .separator {
    display: inline;
    top: 80px;
  }
}


.eap-header-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #fff;
  padding: 0 16px;
  height: 52px;
  position: relative;
}

.eap-header-container__full {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #fff;
  padding: 0 16px;
  height: 52px;
  position: relative;
}

@media (min-width: 769px) {
  .eap-header-container {
    padding: 0 16px;
    margin: 0 auto;
    max-width: 1200px;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    height: 80px;
  }

  .eap-header-container__full {
    padding: 0 16px;
    margin: 0 auto;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    height: 80px;
  }
}

.logo-container {
  height: 3rem;             
  display: -webkit-box;             
  display: -ms-flexbox;             
  display: flex;              
  -webkit-box-align: center;              
      -ms-flex-align: center;              
          align-items: center;        
  position: relative;
}

@media (min-width: 769px) {
  .logo-container {
    width: 200px;
    height: 80px;
    margin-right: 40px;
  }
}

.eap-header-logo {
  cursor: pointer;
  display: block;
  width: auto;
  max-width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: left;
     object-position: left;
}

@media (min-width: 769px) {
  .eap-header-logo {
    width: 100%;
    height: 100%;
    -o-object-fit: contain;
       object-fit: contain;
  }
}

.nav {
  display: none;
  width: 100%;
}

@media (min-width: 769px) {
  .nav {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

.menu-item {
  width: 90px;
  height: 44px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
}

@media (min-width: 769px) {
  .menu-item {
    width: 103px;
    height: 80px;
  }
}

.menu-link {
  font-weight: bold;
  color: black;
  text-decoration: none;
}

.menu-link:hover {
  color: #2b96ed;
  font-weight: 700;
}

@media (min-width: 769px) {
  .menu-link {
    font-size: 18px;
    line-height: 1.44;
  }
}

.submenu {
  display: none;
  position: absolute;
  width: 170px;
  top: 66px;
  left: 0;
  padding: 8px 0;
  background-color: #fff;
  z-index: 10;
  border: 1px solid #ececec;
  border-radius: 8px;
  -webkit-box-shadow: 0 6px 15px 0 rgba(0, 0, 0, 0.08);
          box-shadow: 0 6px 15px 0 rgba(0, 0, 0, 0.08);
}

.submenu-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 9px 20px;
  text-decoration: none;
  font-size: 16px;
  line-height: 1.5;
  font-weight: 500;
  color: #666;
  white-space: nowrap;
}

.submenu-link:hover {
  color: #2b96ed;
}

.menu-item:hover .submenu {
  display: block;
}

.active {
  background-color: #fff;
  color: #2b96ed;
}

.indicator {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  width: 87px;
  margin: 0 auto;
  height: 4px;
  background-color: #2b96ed;
}

/* 액션 버튼 영역 */
.actions {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 16px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

/* 하단 서브 헤더 영역 (md 이상에서 보임) */
.header-sub {
  background-color: #fafafa;
  height: 52px;
  display: none;
}

@media (min-width: 769px) {
  .header-sub {
    display: block;
  }
}

/* 서브 헤더 내부 컨테이너 */
.sub-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 20px;
  padding: 0 16px;
  max-width: 1200px;
  height: 100%;
  margin: 0 auto;
}

/* 테넌트 타이틀 */
.tenant-title {
  max-width: 260px;
  color: black;
  font-size: 1rem;
  font-weight: 500;
  overflow: hidden;
  display: -webkit-box;
  line-clamp: 2;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

/* 테넌트 설명 */
.tenant-desc {
  font-size: 15px;
  line-height: 1.47;
  font-weight: 500;
  overflow: hidden;
  display: -webkit-box;
  line-clamp: 2;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  color: #4a4a4a;
}

.button-container {
  display: none;
  gap: 16px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

@media (min-width: 769px) {
  .button-container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

/* 외부 버튼 컨테이너 */
.app-download-button {
  min-width: 101px;
  min-height: 42px;
  border-radius: 8px;
  background-color: #f5f5f5; /* bg-black-200 색상 */
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  cursor: pointer;
  position: relative;
  -webkit-transition: background-color 0.3s ease;
  -o-transition: background-color 0.3s ease;
  transition: background-color 0.3s ease;
}

.app-download-button:hover {
  background-color: #dcdcdc; /* hover 시 변경 */
}

/* 버튼 텍스트 */
.app-download-button-text {
  font-size: 1rem; /* text-base */
  color:#2b96ed; /* text-primary */
  font-weight: bold;
}

.app-download-tooltip {
  width: 424px;
  height: 182px;
  position: absolute;
  top: 56px;
  right: -100px;
  z-index: 1000;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 24px 28px;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #fff;
  border: 1px solid #d8d8d8;
  -webkit-box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.1);
          box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.1);
  border-radius: 12px;
}

.app-download-tooltip p {
  font-size: 22px;
  font-weight: bold;
  font-stretch: normal;
  font-style: normal;
  line-height: 1.45;
  letter-spacing: normal;
  text-align: left;
  color: #111;
}

.app-download-tooltip span {
  font-size: 22px;
  font-weight: bold;
  font-stretch: normal;
  font-style: normal;
  line-height: 1.45;
  letter-spacing: normal;
  color: #2b96ed;
}

.app-download-tooltip::before {
  content: '';
  position: absolute;
  top: -10px;
  left: 265px;
  border-width: 0 7px 10px; 
  border-style: solid;
  border-color: transparent transparent #d8d8d8 transparent;
  z-index: 1000;
}

.app-download-tooltip::after {
  content: '';
  position: absolute;
  top: -9px;
  left: 266px; 
  border-width: 0 6px 9px;
  border-style: solid;
  border-color: transparent transparent #fff transparent;
  z-index: 1001; 
}


/* 툴팁 영역 */
.app-download-tooltip-image {
  width: 130px;
  height: 130px;
}

/* 숨김 클래스 */
.hidden {
  display: none;
}


.login-button-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  min-width: 72px;
  height: 42px;
  background-color: #2b96ed;
  border-radius: 8px;
  cursor: pointer;
}

.login-button-container:hover {
  background-color: #5daaea;
}

.login-button-text {
  color: #fff;
  font-size: 1rem;
  font-weight: 700;
}

.logout-button-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  min-width: 72px;
  padding-left: 18px;
  padding-right: 18px;
  height: 42px;
  border: 1px solid #2b96ed;
  background-color: #fff;
  border-radius: 8px;
  cursor: pointer;
}

.logout-button-container:hover {
  background-color: #fafafa;
}

.logout-button-text {
  color: #2b96ed;
  font-size: 1rem;
  font-weight: 700;
}

/* ============================================
   반응형 표시/숨김 클래스
   ============================================ */
.eap-header-desktop-only {
  display: none;
}

@media (min-width: 769px) {
  .eap-header-desktop-only {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

.eap-header-mobile-only {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media (min-width: 769px) {
  .eap-header-mobile-only {
    display: none;
  }
}

/* ============================================
   모바일 메뉴 스타일
   ============================================ */
.mobile-menu {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  background-color: #fff;
  z-index: 2400;
  -webkit-transform: translateX(100%);
      -ms-transform: translateX(100%);
          transform: translateX(100%);
  -webkit-transition: -webkit-transform 0.3s ease-in-out;
  transition: -webkit-transform 0.3s ease-in-out;
  -o-transition: transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.mobile-menu.open {
  -webkit-transform: translateX(0);
      -ms-transform: translateX(0);
          transform: translateX(0);
  z-index: 2400;
}

@media (min-width: 769px) {
  .mobile-menu {
    display: none;
  }
}

/* 모바일 메뉴 헤더 */
.mobile-menu-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 0 16px;
  height: 52px;
  position: relative;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

/* 모바일 메뉴 닫기 버튼 */
.mobile-menu-close {
  width: 24px;
  height: 24px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background-color: #fff;
  border: none;
  cursor: pointer;
  padding: 0;
}

.mobile-menu-close img {
  width: 24px;
  height: 24px;
}

/* 모바일 메뉴 리스트 */
.mobile-menu-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  overflow-y: auto;
}

/* 모바일 메뉴 아이템 */
.mobile-menu-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 14px 16px;
  cursor: pointer;
}

.mobile-menu-item:hover {
  background-color: #fafafa;
}

.mobile-menu-link {
  text-decoration: none;
  font-size: 16px;
  line-height: 1.5;
  font-weight: 500;
  color: #111;
}

.mobile-menu-link:hover {
  color: #2b96ed;
}

/* 모바일 서브메뉴 (아코디언) */
.mobile-submenu {
  background-color: #fafafa;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  -webkit-transition: max-height 0.5s ease-in-out, opacity 0.5s ease-in-out;
  -o-transition: max-height 0.5s ease-in-out, opacity 0.5s ease-in-out;
  transition: max-height 0.5s ease-in-out, opacity 0.5s ease-in-out;
}

.mobile-submenu.expanded {
  max-height: 260px;
  opacity: 1;
}

.mobile-submenu-link {
  display: block;
  padding: 14px 16px 14px 28px;
  text-decoration: none;
  font-size: 16px;
  line-height: 1.5;
  font-weight: 500;
  color: #666;
}

.mobile-submenu-link:hover {
  color: #2b96ed;
}

/* 모바일 메뉴 화살표 아이콘 */
.mobile-menu-icon {
  width: 24px;
  height: 24px;
}

/* 모바일 메뉴 하단 버튼 */
.mobile-menu-footer {
  padding: 20px 16px;
  background-color: #fff;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  border-top: 1px solid #e5e5e5;
}

.mobile-menu-auth-button {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  padding: 8px 12px;
  border-radius: 8px;
  font-size: 15px;
  line-height: 1.47;
  font-weight: bold;
  cursor: pointer;
  border: none;
}

.mobile-menu-auth-button.login {
  background-color: #2b96ed;
  color: #fff;
}

.mobile-menu-auth-button.logout {
  background-color: #fff;
  border: 1px solid #2b96ed;
  color: #2b96ed;
}

/* ============================================
   모바일 헤더 버튼
   ============================================ */
.mobile-header-buttons {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 12px;
  z-index: 99999;
}

@media (min-width: 769px) {
  .mobile-header-buttons {
    display: none;
  }
}

.mobile-hamburger-button {
  width: 24px;
  height: 24px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background-color: #fff;
  border: none;
  cursor: pointer;
  padding: 0;
}

.mobile-hamburger-button img {
  width: 24px;
  height: 24px;
}

.mobile-app-download {
  min-width: 88px;
  height: 36px;
  border-radius: 8px;
  background-color: #f5f5f5;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  cursor: pointer;
}

.mobile-app-download p {
  font-size: 14px;
  line-height: 1.43;
  color: #2b96ed;
  font-weight: bold;
}

/* ============================================
   헤더 로고/타이틀 반응형
   ============================================ */
/* Base: no app button (64px offset) */
.header-logo-title {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 24px;
  width: auto;
  max-width: calc(100vw - 64px);
  margin-right: 8px;
}

/* With app button (164px offset) */
.header-logo-title--with-app-button {
  max-width: calc(100vw - 164px);
  height: 24px;
}

/* mobileHeaderTitle이 있을 때: 모바일에서 로고 숨김 */
.header-logo-title.eap-header-desktop-only {
  display: none;
}

@media (min-width: 769px) {
  .header-logo-title,
  .header-logo-title--with-app-button {
    width: 200px;
    height: 80px;
    max-width: 200px;
    margin-right: 40px;
  }

  /* mobileHeaderTitle이 있을 때: 데스크톱에서 로고 표시 */
  .header-logo-title.eap-header-desktop-only {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

.mobile-page-title {
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  max-width: 60%;
  font-size: 16px;
  line-height: 1.5;
  font-weight: bold;
  color: #111;
  white-space: nowrap;
  overflow: hidden;
  -o-text-overflow: ellipsis;
     text-overflow: ellipsis;
}

@media (min-width: 769px) {
  .mobile-page-title {
    display: none;
  }
}

/*# sourceMappingURL=../sourcemaps/common/header-ba0d46e7.css.map*/